<template>
	<view class="my-userinfo-container">
		<!-- 头像昵称区域 -->
		<view class="top-box">
			<image :src="userinfo.avatarUrl" class="avatar"></image>
			<view class="nickname">
				{{userinfo.nickName}}
			</view>
		</view>
		<!-- 面板的列表区域 -->
		<view class="panel-list">
			<!-- 第一个面板 -->
			<view class="panel">
				<!-- panel的item项 -->
				<view class="panel-item">
					<text>8</text>
					<text>收藏的店铺</text>
				</view>
				<view class="panel-item">
					<text>14</text>
					<text>收藏的商品</text>
				</view>
				<view class="panel-item">
					<text>18</text>
					<text>关注的商品</text>
				</view>
				<view class="panel-item">
					<text>84</text>
					<text>足迹</text>
				</view>
			</view>
			<!-- 第二个面板区域 -->
			<view class="panel2">
				<view class="panel-title">
					我的订单
				</view>
				<view class="panel-body">
					<view class="panel-item">
						<image src="/static/my-icons/icon1.png" class="icon"></image>
						<text>待付款</text>
					</view>
					<view class="panel-item">
						<image src="/static/my-icons/icon2.png" class="icon"></image>
						<text>待收货</text>
					</view>
					<view class="panel-item">
						<image src="/static/my-icons/icon3.png" class="icon"></image>
						<text>退款/退货</text>
					</view>
					<view class="panel-item">
						<image src="/static/my-icons/icon4.png" class="icon"></image>
						<text>全部订单</text>
					</view>
				</view>
			</view>
			<!-- 第三个面板 -->
			<view class="panel3">
				<view class="panel-list-item">
					<text>收货地址</text>
					<uni-icons type=arrowright size="15"></uni-icons>
				</view>
				<view class="panel-list-item">
					<text>联系客服</text>
					<uni-icons type=arrowright size="15"></uni-icons>
				</view>
				<view class="panel-list-item" @click="logout">
					<text>退出登录</text>
					<uni-icons type=arrowright size="15"></uni-icons>
				</view>
			</view>
		</view>
	</view>
</template>

<script>
	import {mapState, mapMutations} from 'vuex'
	export default {
		name:"my-userinfo",
		data() {
			return {
				
			};
		},
		computed: {
			// 将m_user中的userinfo映射到当前页面中使用
			...mapState('m_user', ['userinfo'])
			
		},
		methods: {
			...mapMutations('m_user', ['updateUserInfo', 'updateToken', 'updateAddress']),
			// 退出登录
			async logout(){
				// 询问用户是否退出登录
				const [err, succ] = await uni.showModal({
					title:'提示',
					content: '确认退出登录吗？'
				}).catch(err => err)
				 if(succ && succ.confirm){
					 // 用户确认了退出登录的操作
					 // 需要清空vuex中的userinfo, token, address
					 this.updateUserInfo({})
					 this.updateToken('')
					 this.updateAddress({})
				 }
			}
		}
	}
</script>

<style lang="scss">
.my-userinfo-container{
	height: 100%;
	// 为整个组件的结构添加浅灰色的背景
	background-color: #f4f4f4;
	.top-box{
		height: 400rpx;
		background-color: #c00000;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column;
		.avatar{
			width: 90px;
			height: 90px;
			border-radius: 45px;
			border: 2px solid #fff;
			box-shadow: 0 1px 5px black;
			
		}
		.nickname{
			font-size: 16px;
			color: #fff;
			font-weight: bold;
			margin-top: 10px;
		}
	}
	.panel-list{
		padding: 0 10px;
		position: relative;
		top: -10px;
		.panel{
			background-color: white;
			border-radius: 3px;
			margin-bottom: 8px;
			display: flex;
			justify-content: space-around;
			.panel-item{
				display: flex;
				flex-direction: column;
				align-items: center;
				justify-content: space-around;
				padding: 10px 0;
				font-size: 13px;
			}
		}
		.panel2{
			background-color: white;
			border-radius: 3px;
			margin-bottom: 8px;
			.panel-title{
				line-height: 45px;
				padding-left: 10px;
				font-size: 15px;
				border-bottom: 1px solid #F4F4F4;
			}
			.panel-body{
				display: flex;
				justify-content: space-around;
				.panel-item{
					display: flex;
					flex-direction: column;
					align-items: center;
					justify-content: space-around;
					padding: 10px 0;
					font-size: 13px;
					.icon{
						width: 35px;
						height: 35px;
					}
				}
			}
			
		}
		.panel3{
			background-color: white;
			border-radius: 3px;
			margin-bottom: 8px;
			.panel-list-item{
				display: flex;
				justify-content: space-between;
				align-items: center;
				font-size: 15px;
				padding: 0 10px;
				line-height: 45px;
				
			}
		}
	}
}
</style>